<?php

/**
 * Zend Framework
 *
 * LICENSE
 *
 * This source file is subject to the new BSD license that is bundled
 * with this package in the file LICENSE.txt.
 * It is also available through the world-wide-web at this URL:
 * http://framework.zend.com/license/new-bsd
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@zend.com so we can send you a copy immediately.
 *
 * @category   Zend
 * @package    Zend_Gdata
 * @subpackage Photos
 * @copyright  Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license/new-bsd     New BSD License
 * @version    $Id: PhotoEntry.php 23775 2011-03-01 17:25:24Z ralph $
 */

/**
 * @see Zend_Gdata_MediaEntry
 */
require_once 'Zend/Gdata/Media/Entry.php';

/**
 * @see Zend_Gdata_Photos_Extension_PhotoId
 */
require_once 'Zend/Gdata/Photos/Extension/PhotoId.php';

/**
 * @see Zend_Gdata_Photos_Extension_Version
 */
require_once 'Zend/Gdata/Photos/Extension/Version.php';

/**
 * @see Zend_Gdata_Photos_Extension_AlbumId
 */
require_once 'Zend/Gdata/Photos/Extension/AlbumId.php';

/**
 * @see Zend_Gdata_Photos_Extension_Id
 */
require_once 'Zend/Gdata/Photos/Extension/Id.php';

/**
 * @see Zend_Gdata_Photos_Extension_Width
 */
require_once 'Zend/Gdata/Photos/Extension/Width.php';

/**
 * @see Zend_Gdata_Photos_Extension_Height
 */
require_once 'Zend/Gdata/Photos/Extension/Height.php';

/**
 * @see Zend_Gdata_Photos_Extension_Size
 */
require_once 'Zend/Gdata/Photos/Extension/Size.php';

/**
 * @see Zend_Gdata_Photos_Extension_Client
 */
require_once 'Zend/Gdata/Photos/Extension/Client.php';

/**
 * @see Zend_Gdata_Photos_Extension_Checksum
 */
require_once 'Zend/Gdata/Photos/Extension/Checksum.php';

/**
 * @see Zend_Gdata_Photos_Extension_Timestamp
 */
require_once 'Zend/Gdata/Photos/Extension/Timestamp.php';

/**
 * @see Zend_Gdata_Photos_Extension_CommentingEnabled
 */
require_once 'Zend/Gdata/Photos/Extension/CommentingEnabled.php';

/**
 * @see Zend_Gdata_Photos_Extension_CommentCount
 */
require_once 'Zend/Gdata/Photos/Extension/CommentCount.php';

/**
 * @see Zend_Gdata_Exif_Extension_Tags
 */
require_once 'Zend/Gdata/Exif/Extension/Tags.php';

/**
 * @see Zend_Gdata_Geo_Extension_GeoRssWhere
 */
require_once 'Zend/Gdata/Geo/Extension/GeoRssWhere.php';

/**
 * @see Zend_Gdata_App_Extension_Category
 */
require_once 'Zend/Gdata/App/Extension/Category.php';

/**
 * Data model class for a Comment Entry.
 *
 * To transfer user entries to and from the servers, including
 * creating new entries, refer to the service class,
 * Zend_Gdata_Photos.
 *
 * This class represents <atom:entry> in the Google Data protocol.
 *
 * @category   Zend
 * @package    Zend_Gdata
 * @subpackage Photos
 * @copyright  Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license/new-bsd     New BSD License
 */
class Zend_Gdata_Photos_PhotoEntry extends Zend_Gdata_Media_Entry {
	
	protected $_entryClassName = 'Zend_Gdata_Photos_PhotoEntry';
	
	/**
	 * gphoto:id element
	 *
	 * @var Zend_Gdata_Photos_Extension_Id
	 */
	protected $_gphotoId = null;
	
	/**
	 * gphoto:albumid element
	 *
	 * @var Zend_Gdata_Photos_Extension_AlbumId
	 */
	protected $_gphotoAlbumId = null;
	
	/**
	 * gphoto:version element
	 *
	 * @var Zend_Gdata_Photos_Extension_Version
	 */
	protected $_gphotoVersion = null;
	
	/**
	 * gphoto:width element
	 *
	 * @var Zend_Gdata_Photos_Extension_Width
	 */
	protected $_gphotoWidth = null;
	
	/**
	 * gphoto:height element
	 *
	 * @var Zend_Gdata_Photos_Extension_Height
	 */
	protected $_gphotoHeight = null;
	
	/**
	 * gphoto:size element
	 *
	 * @var Zend_Gdata_Photos_Extension_Size
	 */
	protected $_gphotoSize = null;
	
	/**
	 * gphoto:client element
	 *
	 * @var Zend_Gdata_Photos_Extension_Client
	 */
	protected $_gphotoClient = null;
	
	/**
	 * gphoto:checksum element
	 *
	 * @var Zend_Gdata_Photos_Extension_Checksum
	 */
	protected $_gphotoChecksum = null;
	
	/**
	 * gphoto:timestamp element
	 *
	 * @var Zend_Gdata_Photos_Extension_Timestamp
	 */
	protected $_gphotoTimestamp = null;
	
	/**
	 * gphoto:commentCount element
	 *
	 * @var Zend_Gdata_Photos_Extension_CommentCount
	 */
	protected $_gphotoCommentCount = null;
	
	/**
	 * gphoto:commentingEnabled element
	 *
	 * @var Zend_Gdata_Photos_Extension_CommentingEnabled
	 */
	protected $_gphotoCommentingEnabled = null;
	
	/**
	 * exif:tags element
	 *
	 * @var Zend_Gdata_Exif_Extension_Tags
	 */
	protected $_exifTags = null;
	
	/**
	 * georss:where element
	 *
	 * @var Zend_Gdata_Geo_Extension_GeoRssWhere
	 */
	protected $_geoRssWhere = null;
	
	/**
	 * Create a new instance.
	 *
	 * @param DOMElement $element (optional) DOMElement from which this
	 * object should be constructed.
	 */
	public function __construct($element = null) {
		$this->registerAllNamespaces ( Zend_Gdata_Photos::$namespaces );
		parent::__construct ( $element );
		
		$category = new Zend_Gdata_App_Extension_Category ( 'http://schemas.google.com/photos/2007#photo', 'http://schemas.google.com/g/2005#kind' );
		$this->setCategory ( array ($category ) );
	}
	
	/**
	 * Retrieves a DOMElement which corresponds to this element and all
	 * child properties.  This is used to build an entry back into a DOM
	 * and eventually XML text for application storage/persistence.
	 *
	 * @param DOMDocument $doc The DOMDocument used to construct DOMElements
	 * @return DOMElement The DOMElement representing this element and all
	 * child properties.
	 */
	public function getDOM($doc = null, $majorVersion = 1, $minorVersion = null) {
		$element = parent::getDOM ( $doc, $majorVersion, $minorVersion );
		if ($this->_gphotoAlbumId !== null) {
			$element->appendChild ( $this->_gphotoAlbumId->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoId !== null) {
			$element->appendChild ( $this->_gphotoId->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoVersion !== null) {
			$element->appendChild ( $this->_gphotoVersion->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoWidth !== null) {
			$element->appendChild ( $this->_gphotoWidth->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoHeight !== null) {
			$element->appendChild ( $this->_gphotoHeight->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoSize !== null) {
			$element->appendChild ( $this->_gphotoSize->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoClient !== null) {
			$element->appendChild ( $this->_gphotoClient->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoChecksum !== null) {
			$element->appendChild ( $this->_gphotoChecksum->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoTimestamp !== null) {
			$element->appendChild ( $this->_gphotoTimestamp->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoCommentingEnabled !== null) {
			$element->appendChild ( $this->_gphotoCommentingEnabled->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_gphotoCommentCount !== null) {
			$element->appendChild ( $this->_gphotoCommentCount->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_exifTags !== null) {
			$element->appendChild ( $this->_exifTags->getDOM ( $element->ownerDocument ) );
		}
		if ($this->_geoRssWhere !== null) {
			$element->appendChild ( $this->_geoRssWhere->getDOM ( $element->ownerDocument ) );
		}
		return $element;
	}
	
	/**
	 * Creates individual Entry objects of the appropriate type and
	 * stores them as members of this entry based upon DOM data.
	 *
	 * @param DOMNode $child The DOMNode to process
	 */
	protected function takeChildFromDOM($child) {
		$absoluteNodeName = $child->namespaceURI . ':' . $child->localName;
		
		switch ($absoluteNodeName) {
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'albumid' :
				$albumId = new Zend_Gdata_Photos_Extension_AlbumId ();
				$albumId->transferFromDOM ( $child );
				$this->_gphotoAlbumId = $albumId;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'id' :
				$id = new Zend_Gdata_Photos_Extension_Id ();
				$id->transferFromDOM ( $child );
				$this->_gphotoId = $id;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'version' :
				$version = new Zend_Gdata_Photos_Extension_Version ();
				$version->transferFromDOM ( $child );
				$this->_gphotoVersion = $version;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'width' :
				$width = new Zend_Gdata_Photos_Extension_Width ();
				$width->transferFromDOM ( $child );
				$this->_gphotoWidth = $width;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'height' :
				$height = new Zend_Gdata_Photos_Extension_Height ();
				$height->transferFromDOM ( $child );
				$this->_gphotoHeight = $height;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'size' :
				$size = new Zend_Gdata_Photos_Extension_Size ();
				$size->transferFromDOM ( $child );
				$this->_gphotoSize = $size;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'client' :
				$client = new Zend_Gdata_Photos_Extension_Client ();
				$client->transferFromDOM ( $child );
				$this->_gphotoClient = $client;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'checksum' :
				$checksum = new Zend_Gdata_Photos_Extension_Checksum ();
				$checksum->transferFromDOM ( $child );
				$this->_gphotoChecksum = $checksum;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'timestamp' :
				$timestamp = new Zend_Gdata_Photos_Extension_Timestamp ();
				$timestamp->transferFromDOM ( $child );
				$this->_gphotoTimestamp = $timestamp;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'commentingEnabled' :
				$commentingEnabled = new Zend_Gdata_Photos_Extension_CommentingEnabled ();
				$commentingEnabled->transferFromDOM ( $child );
				$this->_gphotoCommentingEnabled = $commentingEnabled;
				break;
			case $this->lookupNamespace ( 'gphoto' ) . ':' . 'commentCount' :
				$commentCount = new Zend_Gdata_Photos_Extension_CommentCount ();
				$commentCount->transferFromDOM ( $child );
				$this->_gphotoCommentCount = $commentCount;
				break;
			case $this->lookupNamespace ( 'exif' ) . ':' . 'tags' :
				$exifTags = new Zend_Gdata_Exif_Extension_Tags ();
				$exifTags->transferFromDOM ( $child );
				$this->_exifTags = $exifTags;
				break;
			case $this->lookupNamespace ( 'georss' ) . ':' . 'where' :
				$geoRssWhere = new Zend_Gdata_Geo_Extension_GeoRssWhere ();
				$geoRssWhere->transferFromDOM ( $child );
				$this->_geoRssWhere = $geoRssWhere;
				break;
			default :
				parent::takeChildFromDOM ( $child );
				break;
		
		}
	}
	
	/**
	 * Get the value for this element's gphoto:albumid attribute.
	 *
	 * @see setGphotoAlbumId
	 * @return string The requested attribute.
	 */
	public function getGphotoAlbumId() {
		return $this->_gphotoAlbumId;
	}
	
	/**
	 * Set the value for this element's gphoto:albumid attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_AlbumId The element being modified.
	 */
	public function setGphotoAlbumId($value) {
		$this->_gphotoAlbumId = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:id attribute.
	 *
	 * @see setGphotoId
	 * @return string The requested attribute.
	 */
	public function getGphotoId() {
		return $this->_gphotoId;
	}
	
	/**
	 * Set the value for this element's gphoto:id attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Id The element being modified.
	 */
	public function setGphotoId($value) {
		$this->_gphotoId = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:version attribute.
	 *
	 * @see setGphotoVersion
	 * @return string The requested attribute.
	 */
	public function getGphotoVersion() {
		return $this->_gphotoVersion;
	}
	
	/**
	 * Set the value for this element's gphoto:version attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Version The element being modified.
	 */
	public function setGphotoVersion($value) {
		$this->_gphotoVersion = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:width attribute.
	 *
	 * @see setGphotoWidth
	 * @return string The requested attribute.
	 */
	public function getGphotoWidth() {
		return $this->_gphotoWidth;
	}
	
	/**
	 * Set the value for this element's gphoto:width attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Width The element being modified.
	 */
	public function setGphotoWidth($value) {
		$this->_gphotoWidth = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:height attribute.
	 *
	 * @see setGphotoHeight
	 * @return string The requested attribute.
	 */
	public function getGphotoHeight() {
		return $this->_gphotoHeight;
	}
	
	/**
	 * Set the value for this element's gphoto:height attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Height The element being modified.
	 */
	public function setGphotoHeight($value) {
		$this->_gphotoHeight = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:size attribute.
	 *
	 * @see setGphotoSize
	 * @return string The requested attribute.
	 */
	public function getGphotoSize() {
		return $this->_gphotoSize;
	}
	
	/**
	 * Set the value for this element's gphoto:size attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Size The element being modified.
	 */
	public function setGphotoSize($value) {
		$this->_gphotoSize = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:client attribute.
	 *
	 * @see setGphotoClient
	 * @return string The requested attribute.
	 */
	public function getGphotoClient() {
		return $this->_gphotoClient;
	}
	
	/**
	 * Set the value for this element's gphoto:client attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Client The element being modified.
	 */
	public function setGphotoClient($value) {
		$this->_gphotoClient = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:checksum attribute.
	 *
	 * @see setGphotoChecksum
	 * @return string The requested attribute.
	 */
	public function getGphotoChecksum() {
		return $this->_gphotoChecksum;
	}
	
	/**
	 * Set the value for this element's gphoto:checksum attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Checksum The element being modified.
	 */
	public function setGphotoChecksum($value) {
		$this->_gphotoChecksum = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:timestamp attribute.
	 *
	 * @see setGphotoTimestamp
	 * @return string The requested attribute.
	 */
	public function getGphotoTimestamp() {
		return $this->_gphotoTimestamp;
	}
	
	/**
	 * Set the value for this element's gphoto:timestamp attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_Timestamp The element being modified.
	 */
	public function setGphotoTimestamp($value) {
		$this->_gphotoTimestamp = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:commentCount attribute.
	 *
	 * @see setGphotoCommentCount
	 * @return string The requested attribute.
	 */
	public function getGphotoCommentCount() {
		return $this->_gphotoCommentCount;
	}
	
	/**
	 * Set the value for this element's gphoto:commentCount attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_CommentCount The element being modified.
	 */
	public function setGphotoCommentCount($value) {
		$this->_gphotoCommentCount = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's gphoto:commentingEnabled attribute.
	 *
	 * @see setGphotoCommentingEnabled
	 * @return string The requested attribute.
	 */
	public function getGphotoCommentingEnabled() {
		return $this->_gphotoCommentingEnabled;
	}
	
	/**
	 * Set the value for this element's gphoto:commentingEnabled attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Photos_Extension_CommentingEnabled The element being modified.
	 */
	public function setGphotoCommentingEnabled($value) {
		$this->_gphotoCommentingEnabled = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's exif:tags attribute.
	 *
	 * @see setExifTags
	 * @return string The requested attribute.
	 */
	public function getExifTags() {
		return $this->_exifTags;
	}
	
	/**
	 * Set the value for this element's exif:tags attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Exif_Extension_Tags The element being modified.
	 */
	public function setExifTags($value) {
		$this->_exifTags = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's georss:where attribute.
	 *
	 * @see setGeoRssWhere
	 * @return string The requested attribute.
	 */
	public function getGeoRssWhere() {
		return $this->_geoRssWhere;
	}
	
	/**
	 * Set the value for this element's georss:where attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Geo_Extension_GeoRssWhere The element being modified.
	 */
	public function setGeoRssWhere($value) {
		$this->_geoRssWhere = $value;
		return $this;
	}
	
	/**
	 * Get the value for this element's media:group attribute.
	 *
	 * @see setMediaGroup
	 * @return string The requested attribute.
	 */
	public function getMediaGroup() {
		return $this->_mediaGroup;
	}
	
	/**
	 * Set the value for this element's media:group attribute.
	 *
	 * @param string $value The desired value for this attribute.
	 * @return Zend_Gdata_Media_Extension_MediaGroup The element being modified.
	 */
	public function setMediaGroup($value) {
		$this->_mediaGroup = $value;
		return $this;
	}

}
